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^ (57) Abstract: A system and method for determining a best match from a plurality of matches received in response to a search input 
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Match Resolution Circuit for An Associative Memory 
Related Application 

The subject matter of the present application is related to and claims priority, under 35 
U.S.C. § 119(e), from U.S. provisional patent application serial no. 60/148,403, entitled 
••Match Resolution Circuit for Content Addressable Memory " by Alex E. Henderson and 
Walter E. Croft, which application was filed on August 11, 1999 and is incorporated herein 
by reference. 

Background 

A. Technical Field 

The present invention relates generally to associative memories, and in particular to 
content addressable memories. More particularly, the present invention relates to an 
associative memory having a match resolution circuit for determining a best match from 
among multiple matches. 

B. Background of the Invention 

An associative memory, such as a content addressable memory (CAM), is a device 
that permits the contents of the memory to be searched and matched instead of having to 
specify a memory location address in order to retrieve data from the memory. A CAM may 
be used to accelerate any application requiring fast searching of a database, list, or pattern, 
such as in database machines, image or voice recognition, or computer and communication 
networks. A CAM provides a performance advantage over conventional memory devices 
with conventional memory search algorithms, such as binary or tree-based searches, by 
comparing the desired information against the entire list of entries simultaneously, giving an 
order-of-magnitude reduction in search time. For example, a binary search through a 
database of 1000 entries may take ten separate search steps whereas a CAM device with 1000 
entries may be searched in a single operation resulting in a search which takes ten times less 
time. One example of an application in which CAM devices are often used is to store a 
routing table for high speed switching systems which need to rapidly search the routing table 
to look for a matching destination address so that a data packet may be routed to the 
appropriate destination address. 

A CAM device is organized somewhat differently from typical SRAM or DRAM 
devices. Information stored in a CAM may be accessed by comparing the data stored in the 
memory with data placed in a special register known as a search input or compare register as 
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opposed to RAM devices in which information is accessed by specifying a particular memory 
address. If there is a match in particular memory locations with every corresponding bit in 
the register, a Match Flag is asserted to let the user know that the data in the register was 
found in the CAM device. Thus, with a CAM device, the user supplies a piece of data she 
5 would like to match to the CAM and gets back the address of any matching pieces of data in 
the CAM. There are two common types of CAM memory, binary CAM and ternary CAM. 
Binary cam requires an exact match of all bits in the search input and comparand for a match. 
Ternary CAM uses a mask to allow some bits to be treated as "don't care" bits and ignored in 
the determination of a match. 
10 Data in a Binary CAM location typically comprises 2 fields: a comparand and an 

associated data field. Unlike a random access memory ("RAM"), when a search is performed 
on a CAM, all comparands in a CAM are compared simultaneously with a search input stored 
in a register. As each comparand is compared with the search input, a match line for that 
comparand is activated if the comparand matches the search word. Prior art ternary CAM 
15 devices may also contain an additional field known as a mask. The mask may be used to 
filter off portions of the comparand during the search procedure. In other words, the mask 
allows a comparison between the search input and only certain portions of the comparand as 
determined by the mask. 

A search on a CAM may result in several matches in response to the search input, 
20 however, only one result should be returned. Therefore, one problem in the prior art is 
determining which match from a plurality of matches should be returned as the best match for 
a particular search input. One solution in the prior art is to implement a priority resolution 
circuit that uses the position of the data item in the CAM array to determine which match to 
output. One disadvantage in using a priority resolution circuit based on the position of the 
25 data item in the CAM array is that it only offers one criteria, (i.e. position) for determining a 
best match. Additionally, in order to change the priority of a particular CAM data item, it is 
necessary to move the data items to different positions in the CAM array. This process is 
cumbersome and slows down the operation of the CAM.Accordingly it is desirable to provide 
a priority resolution system that is capable of determining a best match among a plurality of 
30 CAM matches. . More specifically, it is advantageous to provide a priority resolution system 
that can be dynamically updated and can use criteria other than position to determine a best 
match among a plurality of matches. 
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Summary of the Invention 

The present invention overcomes the deficiencies and limitations of the prior art with 
a unique system and method for determining a best match from a plurality of matches 
resulting in response to a search input performed on an associative memory. The system and 

5 method for determining a best match from a plurality of matches comprises a priority field 
associated with each data item stored in the associative memory. The priority field 
corresponds to criteria that is used to order the priority of the data items. A match resolution 
module is coupled to receive match signals from an associative memory and the priority 
fields associated with the matching data entries. The match resolution structure compares the 

10 priority fields of the plurality of matching data items to determine which data item has the 
highest priority. The match resolution structure then indicates the data item having the 
highest priority as the best match of the associative memory for the particular search input. 

These and other features and advantages of the present invention may be better 
understood by considering the following detailed description of preferred embodiments of the 

15 invention. In the course of this description, reference will be frequently made to the attached 
drawings. 

Brief Description of the Drawings 

Fig. 1 is a block diagram of one embodiment of a CAM including a priority field in 
accordance with the present invention. 
20 Fig. 2 is a block diagram of one embodiment of a CAM including a match resolution 

circuit. 

Fig. 3 is a block diagram of one embodiment of a method for determining a best 

match. 

Fig. 4 is a block diagram illustrating one embodiment of a match resolution circuit for 
25 a CAM. 

Fig. 5 is a block diagram of another embodiment of a match resolution circuit for a 

CAM. 

Figs. 6a-6d are block diagrams of other embodiments of a match resolution circuit for 
a CAM. 

30 Fig. 7 is one embodiment of a hierarchical match resolution circuit for a CAM. 

Detailed Description of Preferred Embodiments 
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The present invention is particularly applicable to a content addressable memory 
(CAM) device, such as that used as a single or dual port CAM memory, an event-co- 
processor, and a database co-processor, and it is in this context that the invention will be 
described. It will be appreciated, however, that the match resolution module in accordance 
5 with the invention has greater utility and may be used with any type of associative memory 
that accesses data based upon the content of the stored data (rather than the location in which 
that data is stored) and provides multiple matches in response to a search input. 

Referring now to Figure 1, there is shown one embodiment of a CAM having a match 
resolution circuit in accordance with the present invention. The CAM structure comprises a 
10 CAM match structure 102 for storing CAM words or data items, an address decoder 104 for 
addressing the CAM when initially storing data items, and a related memory 106 which may 
be a random access memory (RAM) or a read-only memory (ROM). Typical CAM usage 
involves locating a data item in the CAM match structure 102. A data item is specified by 
entering a search input 108 which compares simultaneously all of the data items stored in the 
15 CAM match structure 102 with the search input 108. A typical CAM search may result in 
finding a plurality of data items which match the search input 108. In order to determine a 
"best match" for the particular search input 108, a priority field 110 associated with each data 
item is evaluated to determine a best match from the plurality of matches. A best match can 
be determined by an arithmetic or logical comparison of the priority fields 110 of all 
20 matching CAM data items. When a best match is found for a particular search input 1 08, the 
apparatus can retrieve additional information concerning the requested data item from the 
related memory 106. As used herein, a "best match" is used to define a single data item from 
a plurality of data items that match the search input 108. As' one skilled in the art will readily 
understand, a best match does not imply that there is only one true absolute match but that in 
25 the context of the priority field 110, there is one data item which will be considered to be a 
best match and will be outputted by the CAM. Examples of various best matches, priority 
fields, and criteria are discussed in more detail below. 

As discussed above, the present invention provides a priority field 1 10 associated with 
each word of the CAM. The priority field 110 allows each data item to be prioritized 
30 according to some criteria. In a preferred embodiment, a priority field 1 10 comprises 16 bits. 
One skilled in the art will realize that the number of bits comprising the priority field 110 will 
depend on the number of bits required to uniquely identify the priority associated with a data 
item. The priority field 110 may correspond to any number of criteria, including but not 
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limited to, a weight field stored in the CAM match structure 102, length of the longest 
contiguous unmasked field in the CAM match structure 102, the total number of unmasked 
bits in the CAM match structure 102, the total number of matching bits resulting from a 
compare, the path length metric derived from a routing protocol such as OSPF, the order of 
5 an order dependent list such as an Access Control List for a router, or position in the CAM 
match structure. Thus, the present invention advantageously allows the use of a variety of 
criteria for ordering the priority of each data item. 

Additionally, because the priority field is a separate field for indicating the priority of 
the data item, the priority of the various data items may be changed by changing the entry in 
10 the priority field. For example, assume a CAM structure contains a first data item A, a 
second data item B, and a third data item C. Further assume that the first data item A has a 
priority field indicating that it has a priority of 1, the second data item B has a priority field 
indicating that it has a priority of 2, and the third data item C has a priority field indicating 
that it has a priority of 3. If priority is determined according to the priority field with the 
25 highest number, then the third data item C, which has a priority of 3, has the highest priority. 
However, if for some reason it is necessary to change the priority of the data items, the 
priority of a data item may be changed simply by changing the priority field. For example, 
assume that the priority field for the first data item A is changed from 1 to 3 and the priority 
field for the third data item C is changed from 3 to 1, then using the same convention that 
20 priority is determined according to the highest number, the first data item A, which now has a 
new priority of 3, has the highest priority. Thus, the present invention advantageously 
provides a simple mechanism for changing the priority of data items by changing the priority 
in the priority field. 

The present invention also provides for hierarchical match' resolution. In other words, 
25 if two or more CAM data items have the same priority according to one priority field criteria, 

then a second priority field criteria can be applied to these entries to determine a best match. 

A preferred embodiment for a hierarchical match resolution system for a CAM is described 

below in more detail with reference to Figure 6. 

Referring now to Figure 2 and Figure 3, there are shown a functional block diagram 
30 of one embodiment of a CAM including a match resolution circuit and a block diagram of 

one embodiment of a method for determining a best match from a plurality of matches. The 

CAM structure 200 comprises a CAM structure 102 coupled to receive a search input 108. 

The CAM structure 102 receives (302) the search input 108 and compares (304) the search 
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input 108 to all the data item entries in the CAM structure 102 as described above. The CAM 
structure 102 then generates (306) a match signal (not shown) for all CAM data items in the 
CAM that match the search input 108. The CAM structure 102 then outputs the match signal 
and the priority field (not shown) to the match resolution circuit 202. The match resolution 
5 circuit 202 evaluates (308) the priority field for each matching CAM data item and 
determines (310) which priority field has the highest priority. The output of the match 
resolution circuit 202 then indicates (312) the CAM data item with the highest priority 
according to the priority field. The indicated item is considered the best match for the 
particular search input 108. Preferably, the output of the match resolution circuit 204 
10 comprises either prioritized match signals or the address of the highest priority matching 
entry. 

Referring now to Figure 4, there is shown a block diagram illustrating one 
embodiment of a CAM match resolution circuit. A CAM match resolution circuit in 
accordance with the present invention comprises a first two port priority resolution circuit 

15 402, a second two port priority resolution circuit 404, and a third two port priority resolution 
circuit 406. The first and second two port priority resolution circuits, 402 and 404, are each 
coupled to receive a match signal and a priority field associated with two CAM data items. 
For example, the first two port priority resolution circuit 402 is coupled to receive a first 
match signal 408a and a first priority field signal 408b from one CAM data item, and a 

20 second match signal 410a and a second priority field signal 408b from a second CAM data 
time. The first two port priority resolution circuit 402 determines which CAM data item has 
the higher priority according to the inputted match and priority field signals and outputs the 
match signal 416a and the priority field signal 416b with the highest priority. Similarly, the 
second two port priority resolution circuit 404 is coupled to receive a first match signal 412a 

25 and a first priority field signal 412b from one CAM data item, and a second match signal 
414a and a second priority field signal 414b from a second CAM data item. The second two 
port priority resolution circuit 404 determines which CAM data item has the higher priority 
according to the inputted match and priority field signals and outputs the match signal 418a 
and the priority field signal 418b with the highest priority. The third two port priority 

30 resolution circuit 406 then compares the results from two port priority resolution circuit 402 
and two port priority resolution circuit 404 and outputs the match signal 420a and the priority 
field signal 420b with the highest priority. For example, if the priority field signal 
corresponds to an assigned priority number, then the CAM data item with the highest priority 
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number would be outputted from two port priority resolution circuit 406. One skilled in the 
art will recognize that the present invention is not limited to only determining the "highest 
priority" but that the principles of the present invention can also be used to determine and 
output the data item with the "lowest" priority. Thus, a CAM match resolution circuit can be 
5 implemented as a stack of two entry match resolution circuits wherein each two entry match 
resolution circuit compares two input values and outputs the greater value. The present 
invention is not limited to the use of three two port priority resolution circuit in a two stage 
circuit for determining a best match, but one skilled in the art will realize that the principles 
of the present invention may be applied to any number of two port priority resolution circuit 
70 arranged in the necessary number of stages for comparing the priority fields of any number of 
data items.. 

Referring now to Figure 5, there is shown a block diagram of one embodiment of one 
row of a match resolution circuit for a CAM. The match resolution circuit 500 comprises a 
priority field Most Significant Bit (MSB) component 502, a compare MSB and OR plane 

25 output component 504, a match signal 508, an AND gate 506, and a MSB OR plane 512. As 
indicated in Figure 5, the match resolution circuit of the present invention incorporates each 
of these elements for each bit in the priority field. In other words, the bits in the priority field 
for a data item are evaluated serially. Figure 5 illustrates these elements for only two bits of 
the priority field in the interest of simplicity. In a preferred embodiment, the match signal 

20 508 is the high order bit of the priority field. For the first bit in the priority field, the match 
signal 508a and the priority field MSB are ANDed together and outputted to the MSB OR 
plane 512a. The result of the MSB OR plane 512a is compared with the MSB of the priority 
field received from the priority field MSB 502a. The result is then used as compare ok or 
enable signal for the next AND gate 506b for the next comparison. This process is repeated 

25 until a determination of the best match is made. Thus, the most significant bit of all priority 
fields are compared to the result of the OR plane. If the priority field bit matches the result a 
compare OK signal is propagated to the next less significant bit. The OR function can also be 
implemented using pre-charge logic as shown in figure 6b. 

Referring now to Figure 6a, there is shown another embodiment of a match resolution 

30 circuit for a CAM in accordance with the present invention. The embodiment described in 
detail in Figure 5 can be implemented using a "look ahead" logic similar to an adder circuit. 
The addition of a "look ahead" logic advantageously improves the speed of the match 
resolution circuit. In another embodiment, the MSB OR plane 512 can be implemented using 
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wide gate structures as described in U.S. Patent No. 5,999,435, entitled "Content Addressable 
Memory Device," by Alex E. Henderson and Walter E. Croft, which patent is incorporated 
herein by reference in its entirety. 

Figure 6b is a precharge logic implementation of the circuit of figure 6a. The OR 
function is implemented by pre-charge transistor 600b, pulldown transistor 601b (one per 
cell) and inverter 602b. Transfer gate 603b and transistor 604b implement the AND function. 
The compare function is implemented by the pre-charge logic complex gate comprising 
transistors 605b through 609b and inverter 610b. Transistors 605b and 609b are controlled 
by a timing signal generated by a dummy row or other timing method. The timing strobe is 
required to prevent a false enable out from corrupting the result of the next cell. The timing 
circuits are designed so that the timing strobe occurs after the OR feedback line is stable. 

Figure 6c is a faster version of the circuit of figure 6b. The pre-charge logic OR has 
been divided into multiple sub-circuits comprising N rows (transistors 600c, 601c and 
inverter 602c). The results of the sub-circuits are combined by a second OR circuit 
comprising transistors 603c and 604c. This reduces the loading on the first layer OR 
resulting in increased speed and combines the feedback and second level OR function. 

Figure 6d is a diagram of a match resolution circuit that implements a multi-bit 
priority resolution to further increase speed. Multiple priority bits are decoded and used to 
drive multiple OR planes. The results of the OR functions are encoded to generate an enable 
output. The pre-charge implementations of the OR functions described in 6b and 6c can be 
used to implement the OR planes. For a two bit priority resolution circuit the decodes xl, Ix 
and 1 1 can be used as inputs to the OR planes. 

Referring now to Figure 7, there is shown one embodiment of hierarchical match 
resolution circuit for a CAM. The hierarchical match resolution circuit for CAM cascades 
two or more match resolution circuits, 702 and 704, such that if there are multiple "best" 
matches based on a first criteria (e.g. network path length), a second criteria (e.g. link speed) 
can be used to determine the best match. A hierarchical match resolution circuit for a CAM 
comprises a CAM structure 102 coupled to receive an input search 108, a first match 
resolution module 702, and a second match resolution module 704. As described above, the 
CAM structure 102 receives a search input 108 and compares the search input 108 to all the 
CAM data items. The CAM structure 102 then generates a match signal for each data item 
which matches the search input 108. The search result of the CAM may result in a plurality 
of data items which match the search input 108. In such instances, a first match resolution 
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circuit 702 is coupled to receive the match signals and the first priority fields associated with 
each CAM data item that matched the search input 108. The first match resolution circuit 
702 evaluates the first priority field of each of the matching items and determines which data 
item has the highest priority based on the first priority fields. The first match resolution 
5 circuit 702 may result in multiple data items having equal priority based on the first priority 
field (e.g. when network path length is used). The second priority fields are then evaluated to 
determine a best match best on the second priority field with the highest priority. The data 
item with the second priority field with the highest priority is then outputted as the best 
match. One skilled in the art will recognize that the present invention is not limited to two 
w match resolution circuits but that any number of match resolution circuits may be 
implemented to determine a best match using several criteria. Additionally, for each 
additional criteria used for determining priority, an additional priority field is associated with 
each data item. Thus, if two criteria are used for determining priority in a hierarchical match 
resolution circuit, then preferably each data item includes a first priority field and a second 
15 priority field. Similarly, if three criteria are used for determining priority in a hierarchical 
match resolution circuit, then preferably each data item includes a first priority field, a second 
priority field, and a third priority field. Thus, the present invention advantageously allows 
more than one criteria to be used to determine a best match from a plurality of matches 
resulting from a CAM search. 
20 From the above description, it will be apparent that the invention disclosed herein 

provides a novel and advantageous system and method for determining a best match from a 
plurality of matches determined in response to a search item. The foregoing discussion 
discloses and describes merely exemplary methods and embodiments of the present 
invention. As will be understood by those familiar with the art, the invention may be 
25 embodied in other specific forms without departing from the spirit or essential characteristics 
thereof. Accordingly, the disclosure of the present invention is intended to be illustrative, but 
not limiting, of the scope of the invention, which is set forth in the following claims. 
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We claim: 

11. A match resolution structure for selecting a best match from a plurality of matches, 

2 the plurality of matches determined in response to a search input for an associative memory, 

3 the structure comprising: 

4 a plurality of match inputs, each match input receiving a priority field for indicating a 

5 priority of the match input; and 

6 a match resolution logic, coupled to receive the priority field from at least two match 

7 inputs, for comparing the priority fields and indicating a best match.. 

1 2. The structure of claim 1 wherein the priority field contains the length of the longest 

2 contiguous unmasked field in the data item. 

1 3. The structure of claim 1 wherein the priority field contains the total number of 

2 unmasked bits in the data entry. 

7 4. The structure of claim 1 wherein the priority field contains the prefix length of an IP 

2 address. 

1 5. The structure of claim 1 wherein the priority field contains a path length metric 

2 derived from a routing protocol such as OSPF. 

1 6. The structure of claim 1 wherein the priority field contains the order of an order 

2 dependent list such as an Access Control List for a router. 

J 7. The structure of claim 1 wherein the priority field for a data item may be changed to 

2 indicate a change in priority for that data item. 

1 8. The structure of claim 1 wherein the match resolution logic comprises a stack of two 

2 port priority resolution circuits. 

2 9. The structure of claim 1 further comprising a second priority field associated with 

2 each data item. 

I 1 0. The structure of claim 1 wherein the associative memory is a CAM. 

1 11. A method of operation for a match resolution circuit, the match resolution circuit 

2 being coupled to receive a plurality of data items from an associative memory, each data item 

3 having an associated priority field, the method comprising: 

4 receiving a plurality of match signals for the plurality of data items; and 

5 comparing the priority field and the match signals for the data items to determine a 

6 best match. 

3 12. The method of claim 1 1 wherein the priority field contains the length of the longest 

2 contiguous unmasked field in the data item. 
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1 13. The method of claim 11 wherein the priority field contains the total number of 

2 unmasked bits in the data entry. 

2 14. The method of claim 1 1 wherein the priority field contains the position of data item. 

1 15. The method of claim 1 1 wherein the data item further includes a second priority field, 

2 the method further comprising the step of: 

3 comparing the second priority field associated with the data items for determining a 

4 best match. 

I 16. The method of claim 1 1 wherein the associative memory is a CAM. 

1 17. An associative memory structure for storing and prioritizing a plurality of data items 

2 in the associative memory, the structure comprising: 

3 a match structure for storing a plurality of data items, each data item having a priority 

4 field for prioritizing the plurality of data items; and 

5 a search input, for receiving a search item that is compared simultaneously with the 

6 plurality of data items. 



1 18. The structure of claim 17 wherein the first priority field contains the length of the 

2 longest contiguous unmasked field in the data item. 

1 19. The structure of claim 1 7 wherein the associative memory is a CAM. 

1 20. A method for selecting a best matching data item from a plurality of matching data 

2 items determined in response to a search input, each matching data item having a priority 

3 field, the method comprising: 



4 receiving the priority field for each matching data item; 

5 evaluating the priority field for each matching data item; and 

6 selecting a best matching data item by selecting the priority field with the highest 

7 priority. 

1 21. The method of claim 20 wherein each matching the priority field contains the length 

2 of the longest contiguous unmasked field in the data item. 

1 22. The method of claim 20 wherein the priority field contains the total number of 

2 unmasked bits in the data entry. 

1 23. The method of claim 20 further comprising the step of: 

2 altering the priority of at least one data item by changing the priority field of at least 

3 one data item. 

l 24. A match resolution circuit for selecting a best matching data item from at least a first 



2 data item and a second data item, the at least first data item and second data item matching a 
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3 search input for an associative memory, the first data item including a first priority field and 

4 the second data item including a first priority field, the circuit comprising: 



5 a first input for receiving the first priority field of the first data item; 

6 a second input for receiving the first priority field of the second data item; and 

7 a compare circuit for comparing the first priority field of the first data item and the 

8 first priority field of the second data item and for indicating the first priority 

9 field with the highest priority. 

1 25. The circuit of claim 24 wherein the first and second priority field contain the length of 

2 the longest contiguous unmasked field in the data item 

1 26. The circuit of claim 24 wherein the first and second priority field contain the total 

2 number of unmasked bits in the data item. 

1 27. The circuit of claim 24 wherein the associative memory is a CAM. 

3 28. The circuit of claim 24 wherein the first data item and the second data item each 

2 further include a second priority field, the circuit further comprising: 

3 a third input for receiving the second priority field of the first data item; 

4 a fourth input for receiving the second priority field of the second data item; and 

5 a second compare circuit for comparing the second priority field of the first data item 

6 and the second priority field of the second data item and for indicating the 

7 second priority field with the highest priority. 

2 29. A match resolution circuit for indicating a best match from a plurality of matches 

2 received from an associative memory, the circuit comprising: 

3 a plurality of inputs for receiving a priority field associated with the plurality of 

4 matches; and 

5 a compare circuit, coupled to receive the plurality of inputs, for evaluating the priority 

6 fields associated with the plurality of matches, and indicating a best match 

7 from among the plurality of matches. 
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